<template>
  <view>
    <view class="goods-list">
      <view v-for="(goods,i) in goodsList" :key="i" @click="gotoDetail(goods)">
    <my-goods :goods="goods"></my-goods>
      </view>
    </view>
    
  </view>
</template>

<script>
  export default {
    data() {
      return {
        //请求参数对象
        queryObj:{
          //查询关键词
          query:'',
          //商品分类Id
          cid:'',
          //页码值
          pagenum:1,
          //每页显示多少条数据
          pagesize:10
        },
        //商品列表的数据
        goodsList:[],
        //总数量，用来实现分页
        total:0,
      
      };
      // 是否正在请求数据
      isloading: false
    },
   //将页面跳转时携带的参数，转存到 queryObj 对象中：
    onLoad(options) {
      // console.log(options)
      this.queryObj.query=options.query || ''
      this.queryObj.cid=options.cid || ''
       // console.log(this.queryObj)
       //调用获取商品列表数据的方法
       this.getGoodsList()
       
    },
    methods:{
      // 获取商品列表数据的方法
     async getGoodsList(cb){
       // ** 打开节流阀
       this.isloading=true
       // 发起请求
      const{data:res} =await uni.$http.get('/api/public/v1/goods/search',this.queryObj)
      // ** 关闭节流阀
      this.isloading=false
      // 只要数据请求完毕，就立即按需调用 cb 回调函数
      cb && cb()
      // console.log(res)
      if(res.meta.status !==200) return uni.$showMsg()
      // 为数据赋值
      // this.goodsList = res.message.goods
      // 为数据赋值：通过展开运算符的形式，进行新旧数据的拼接
      this.goodsList=[...this.goodsList,...res.message.goods]
      this.total = res.message.total
      
      },
      gotoDetail(goods){
      uni.navigateTo({
        url:'/subpkg/goods_detail/goods_detail?goods_id='+goods.goods_id
      })
      }
    },
    // 触底的事件
    onReachBottom(){
      // 判断是否还有下一页数据
      if(this.queryObj.pagenum*this.queryObj.pagesize >=this.total) return uni.$showMsg('数据加载完毕！')
      // 判断是否正在请求其它数据，如果是，则不发起额外的请求
      if(this.isloading) return
      //让页码值增+1
     this.queryObj.pagenum+=1
      //重新获取列表数据
     this.getGoodsList() 
     
    },
    onPullDownRefresh(){
      //1.重置关键数据
      this.queryObj.pagenum=1
      this.total=0
      this.isloading=false
      this.goodsList=[]
      //2.重新发起请求
      this.getGoodsList(()=>{uni.stopPullDownRefresh()})
    }
   
  }
</script>

<style lang="scss">
  

</style>
